package 剑指offer;

import java.util.DuplicateFormatFlagsException;
import java.util.Scanner;

/** 

* @author ：soulstones
* @version ：2019年9月30日 下午10:02:45 
* @Description：
* 
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的，但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如，如果输入长度为7的数组{2,3,1,0,2,5,3}，那么对应的输出是第一个重复的数字2。
*/
public class A50数组当中重复的数字 {


		public  static boolean duplicate(int numbers[], int length, int[] duplication) {
		        boolean[] k = new boolean[length];
		        for (int i = 0; i < k.length; i++) {
		            if (k[numbers[i]] == true) {
		                duplication[0] = numbers[i];
		                return true;
		            }
		            k[numbers[i]] = true;
		        }
		        return false;
		    }
		public static void main(String[] args) {
			 Scanner scanner = new Scanner(System.in);
				String s = scanner.nextLine();
				String[] ss = s.split(" ");
				int [] arr=new int [ss.length];
				for (int i = 0; i < arr.length; i++) {
					arr[i]=Integer.parseInt(ss[i]);
				}
				int [] m=new int[arr.length];
				System.out.println(duplicate(arr, arr.length,m ));
		}
}
